//compass lens
// ---- Created with 3Dmigoto v1.2.67 on Fri Dec 01 18:49:06 2017
Texture2D<float4> t16 : register(t16);

Texture2D<float4> t2 : register(t2);

Texture2D<float4> t1 : register(t1);

Texture2D<float4> t0 : register(t0);

SamplerState s2_s : register(s2);

SamplerState s1_s : register(s1);

SamplerState s0_s : register(s0);

cbuffer cb6 : register(b6)
{
  float4 cb6[10];
}

cbuffer cb5 : register(b5)
{
  float4 cb5[14];
}

cbuffer cb0 : register(b0)
{
  float4 cb0[18];
}




// 3Dmigoto declarations
#define cmp -
Texture1D<float4> IniParams : register(t120);
Texture2D<float4> StereoParams : register(t125);


void main(
  float4 v0 : SV_POSITION0,
  linear centroid float4 v1 : TEXCOORD6,
  linear centroid float4 v2 : TEXCOORD7,
  linear centroid float4 v3 : TEXCOORD4,
  float4 v4 : TEXCOORD5,
  linear centroid float4 v5 : COLOR0,
  linear centroid float4 v6 : COLOR1,
  linear centroid float3 v7 : TEXCOORD10,
  linear centroid float w7 : TEXCOORD11,
  linear centroid float4 v8 : TEXCOORD0,
  linear centroid float4 v9 : TEXCOORD1,
  float4 v10 : TEXCOORD2,
  linear centroid float4 v11 : TEXCOORD3,
  out float4 o0 : SV_Target0)
{
  const float4 icb[] = { { 0.0153846154, 0, 0, 0},
                              { 0.753846169, 0, 0, 0},
                              { 0.200000, 0, 0, 0},
                              { 0.938461542, 0, 0, 0},
                              { 0.0615384616, 0, 0, 0},
                              { 0.800000, 0, 0, 0},
                              { 0.246153846, 0, 0, 0},
                              { 0.984615386, 0, 0, 0},
                              { 0.507692337, 0, 0, 0},
                              { 0.261538476, 0, 0, 0},
                              { 0.692307711, 0, 0, 0},
                              { 0.446153849, 0, 0, 0},
                              { 0.553846180, 0, 0, 0},
                              { 0.307692319, 0, 0, 0},
                              { 0.738461554, 0, 0, 0},
                              { 0.492307693, 0, 0, 0},
                              { 0.138461545, 0, 0, 0},
                              { 0.876923084, 0, 0, 0},
                              { 0.0769230798, 0, 0, 0},
                              { 0.815384626, 0, 0, 0},
                              { 0.184615389, 0, 0, 0},
                              { 0.923076928, 0, 0, 0},
                              { 0.123076923, 0, 0, 0},
                              { 0.861538470, 0, 0, 0},
                              { 0.630769253, 0, 0, 0},
                              { 0.384615391, 0, 0, 0},
                              { 0.569230795, 0, 0, 0},
                              { 0.323076934, 0, 0, 0},
                              { 0.676923096, 0, 0, 0},
                              { 0.430769235, 0, 0, 0},
                              { 0.615384638, 0, 0, 0},
                              { 0.369230777, 0, 0, 0},
                              { 0.0461538471, 0, 0, 0},
                              { 0.784615397, 0, 0, 0},
                              { 0.230769232, 0, 0, 0},
                              { 0.969230771, 0, 0, 0},
                              { 0.0307692308, 0, 0, 0},
                              { 0.769230783, 0, 0, 0},
                              { 0.215384617, 0, 0, 0},
                              { 0.953846157, 0, 0, 0},
                              { 0.538461566, 0, 0, 0},
                              { 0.292307705, 0, 0, 0},
                              { 0.723076940, 0, 0, 0},
                              { 0.476923078, 0, 0, 0},
                              { 0.523076952, 0, 0, 0},
                              { 0.276923090, 0, 0, 0},
                              { 0.707692325, 0, 0, 0},
                              { 0.461538464, 0, 0, 0},
                              { 0.169230774, 0, 0, 0},
                              { 0.907692313, 0, 0, 0},
                              { 0.107692309, 0, 0, 0},
                              { 0.846153855, 0, 0, 0},
                              { 0.153846160, 0, 0, 0},
                              { 0.892307699, 0, 0, 0},
                              { 0.0923076943, 0, 0, 0},
                              { 0.830769241, 0, 0, 0},
                              { 0.661538482, 0, 0, 0},
                              { 0.415384620, 0, 0, 0},
                              { 0.600000, 0, 0, 0},
                              { 0.353846163, 0, 0, 0},
                              { 0.646153867, 0, 0, 0},
                              { 0.400000, 0, 0, 0},
                              { 0.584615409, 0, 0, 0},
                              { 0.338461548, 0, 0, 0} };
  float4 r0,r1,r2,r3,r4,r5,r6;
  uint4 bitmask, uiDest;
  float4 fDest;

  r0.xyzw = t1.Sample(s1_s, v8.wz).xyzw;
  r1.xy = t2.Sample(s2_s, v9.xy).yz;
  r0.x = r0.x + -r0.w;
  r0.xyz = float3(1,0,0) + r0.xyz;
  r0.xyz = r0.xyz * float3(2,2,2) + float3(-1,-1,-1);
  r0.w = dot(r0.xyz, r0.xyz);
  r0.w = rsqrt(r0.w);
  r0.xyz = r0.xyz * r0.www;
  r0.w = dot(r0.xyz, v5.xyz);
  r1.z = dot(r0.xyz, v11.xyz);
  r1.y = cb5[6].w * r1.y;
  r1.w = cmp(r0.w >= 0);
  r2.x = max(0, r0.w);
  r2.y = cmp(r1.z >= 0);
  r1.w = r1.w ? r2.y : 0;
  r1.z = log2(r1.z);
  r1.y = r1.y * r1.z;
  r1.y = exp2(r1.y);
  r1.y = r1.w ? r1.y : 0;
  r1.y = min(1, r1.y);
  r0.w = max(0, -r0.w);
  r0.x = dot(r0.xyz, v3.xyz);
  r0.y = saturate(1 + r0.x);
  r0.z = saturate(r0.x);
  r2.yzw = -cb5[9].xyz + cb5[1].xyz;
  r2.yzw = r0.zzz * r2.yzw + cb5[9].xyz;
  r3.xyz = cb5[9].xyz + -cb5[2].xyz;
  r3.xyz = r0.yyy * r3.xyz + cb5[2].xyz;
  r0.y = cmp(0 < r0.x);
  r0.x = cmp(r0.x < 0);
  r0.x = (int)r0.x + (int)-r0.y;
  r0.x = (int)r0.x;
  r0.x = saturate(r0.x);
  r2.yzw = -r3.xyz + r2.yzw;
  r0.xyz = r0.xxx * r2.yzw + r3.xyz;
  r0.xyz = cb5[8].xyz + r0.xyz;
  r0.xyz = v1.xyz + r0.xyz;
  r0.xyz = cb5[5].xyz * r0.www + r0.xyz;
  r2.xyz = cb5[4].xyz * r2.xxx;
  r0.w = 1 + -r1.x;
  r2.xyz = r2.xyz * r0.www + cb5[3].xyz;
  r1.yzw = cb5[6].xyz * r1.yyy;
  r1.xyz = r1.yzw * r1.xxx;
  r3.xyzw = t0.Sample(s0_s, v8.xy).xyzw;
  r3.xyzw = cb6[1].xyzw * r3.xyzw;
  r0.w = saturate(v1.w * r3.w);
  r4.xy = cmp(float2(0,0) < cb6[4].xz);
  r1.w = -cb6[4].y + r0.w;
  r1.w = cmp(r1.w < 0);
  r1.w = r4.x ? r1.w : 0;
  if (r1.w != 0) discard;
  r0.w = max(cb5[0].w, r0.w);
  if (r4.y != 0) {
    r4.xy = (int2)v0.yx;
    r4.zw = (int2)r4.xy & int2(0,0);
    r4.xy = max((int2)-r4.xy, (int2)r4.xy);
    r4.xy = (int2)r4.xy & int2(7,7);
    r5.xy = -(int2)r4.xy;
    r4.xy = r4.zw ? r5.xy : r4.xy;
    r1.w = (uint)r4.y << 3;
    r1.w = (int)r1.w + (int)r4.x;
    r2.w = cmp(0 < w7.x);
    r3.w = cmp(w7.x < 0);
    r2.w = (int)r3.w + (int)-r2.w;
    r2.w = (int)r2.w;
    r1.w = -icb[r1.w+0].x + w7.x;
    r3.w = -1 + r2.w;
    r3.w = 0.5 * r3.w;
    r1.w = r2.w * r1.w + r3.w;
    r1.w = cmp(r1.w < 0);
    if (r1.w != 0) discard;
  }
  r1.w = cb5[12].z + -v6.w;
  r1.w = max(0, r1.w);
  r4.xyz = cb0[15].xyz * -r1.www;
  r4.xyz = float3(1.44269502,1.44269502,1.44269502) * r4.xyz;
  r4.xyz = exp2(r4.xyz);
  r5.xyz = cb0[16].xyz * -r1.www;
  r5.xyz = float3(1.44269502,1.44269502,1.44269502) * r5.xyz;
  r5.xyz = exp2(r5.xyz);
  r2.xyz = r5.xyz * r2.xyz;
  r0.xyz = r4.xyz * r0.xyz;
  r1.xyz = r5.xyz * r1.xyz;
  r4.xy = cb0[12].xy * v0.xy;
  r4.xy = (int2)r4.xy;
  r4.zw = float2(0,0);
  r4.xyzw = t16.Load(r4.xyz).xyzw;
  r5.xyz = cb0[10].www * r2.xyz;
  r4.yzw = r5.xyz * r4.yzw;
  r1.w = -1 + r4.x;
  r1.w = r0.w * r1.w + 1;
  r2.xyz = r4.yzw * r0.www + r2.xyz;
  r0.xyz = r0.xyz * r1.www + v7.xyz;
  r1.w = 1 + -v2.w;
  r1.w = saturate(1 + -r1.w);
  r0.xyz = r2.xyz * r1.www + r0.xyz;
  r0.xyz = r0.xyz * r3.xyz;
  r1.xyz = r1.xyz * r1.www;
  r0.xyz = r0.xyz * r0.www + r1.xyz;
  switch (cb5[11].x) {
    case 1 :    case 3 :    r1.y = cb5[13].y + cb5[12].z;
    r2.xyz = cb6[9].xyz + -v6.xyz;
    r1.z = dot(r2.xyz, r2.xyz);
    r1.z = sqrt(r1.z);
    r1.w = cmp(cb6[9].y < r1.y);
    if (r1.w != 0) {
      r2.x = -cb6[9].y + v6.y;
      r2.x = max(0, r2.x);
      r2.x = 9.99999975e-006 + r2.x;
      r2.y = -cb6[9].y + r1.y;
      r2.x = saturate(r2.y / r2.x);
      r2.y = r2.x * r1.z;
      r2.z = -r1.z * r2.x + r1.z;
      r2.w = cmp(0 < r2.z);
      if (r2.w != 0) {
        r2.x = 1 + -r2.x;
        r2.x = r2.x * r1.z;
        r2.w = v6.y + -r1.y;
        r3.x = 9.99999975e-006 + r2.z;
        r3.y = abs(r2.w) / r3.x;
        r3.y = cb5[10].x * r3.y;
        r3.z = cmp(r3.y == 0.000000);
        r3.w = -r3.y * r2.x;
        r3.w = 1.44269502 * r3.w;
        r3.w = exp2(r3.w);
        r3.w = 1 + -r3.w;
        r3.y = r3.w / r3.y;
        r3.y = r3.z ? r2.x : r3.y;
        r3.z = min(v6.y, r1.y);
        r3.z = -cb5[10].x * r3.z;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = -cb5[10].y * r3.z;
        r3.y = r3.z * r3.y;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = min(1, r3.y);
        r2.w = r2.w / r3.x;
        r2.w = cb0[14].z * r2.w;
        r3.x = cmp(r2.w == 0.000000);
        r3.z = -r2.w * r2.x;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = 1 + -r3.z;
        r2.w = r3.z / r2.w;
        r2.x = r3.x ? r2.x : r2.w;
        r2.w = -cb0[14].x + r1.y;
        r2.w = -cb0[14].z * r2.w;
        r2.w = 1.44269502 * r2.w;
        r2.w = exp2(r2.w);
        r2.w = -cb0[14].y * r2.w;
        r2.x = r2.w * r2.x;
        r2.x = 1.44269502 * r2.x;
        r2.x = exp2(r2.x);
        r2.x = min(1, r2.x);
        r2.x = r3.y * r2.x;
      } else {
        r2.x = 1;
      }
      r2.y = -cb5[12].w * r2.y;
      r2.y = 1.44269502 * r2.y;
      r2.y = exp2(r2.y);
      r2.y = min(1, r2.y);
    } else {
      r2.w = cb6[9].y + -v6.y;
      r2.w = max(0, r2.w);
      r2.w = 9.99999975e-006 + r2.w;
      r3.x = cb6[9].y + -r1.y;
      r2.w = saturate(r3.x / r2.w);
      r2.z = r2.w * r1.z;
      r3.x = -r1.z * r2.w + r1.z;
      r1.y = max(v6.y, r1.y);
      r3.y = -cb6[9].y + r1.y;
      r1.z = r1.z * r2.w + 9.99999975e-006;
      r2.w = abs(r3.y) / r1.z;
      r2.w = cb5[10].x * r2.w;
      r3.z = cmp(r2.w == 0.000000);
      r3.w = -r2.w * r2.z;
      r3.w = 1.44269502 * r3.w;
      r3.w = exp2(r3.w);
      r3.w = 1 + -r3.w;
      r2.w = r3.w / r2.w;
      r2.w = r3.z ? r2.z : r2.w;
      r1.y = min(cb6[9].y, r1.y);
      r1.y = -cb5[10].x * r1.y;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.y = -cb5[10].y * r1.y;
      r1.y = r1.y * r2.w;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.z = r3.y / r1.z;
      r1.z = cb0[14].z * r1.z;
      r2.w = cmp(r1.z == 0.000000);
      r3.y = -r1.z * r2.z;
      r3.y = 1.44269502 * r3.y;
      r3.y = exp2(r3.y);
      r3.y = 1 + -r3.y;
      r1.z = r3.y / r1.z;
      r1.z = r2.w ? r2.z : r1.z;
      r2.w = cb6[9].y + -cb0[14].x;
      r2.w = -cb0[14].z * r2.w;
      r2.w = 1.44269502 * r2.w;
      r2.w = exp2(r2.w);
      r2.w = -cb0[14].y * r2.w;
      r1.z = r2.w * r1.z;
      r1.z = 1.44269502 * r1.z;
      r1.z = exp2(r1.z);
      r1.yz = min(float2(1,1), r1.yz);
      r2.x = r1.y * r1.z;
      r1.y = -cb5[12].w * r3.x;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r2.y = min(1, r1.y);
    }
    r1.y = cb5[12].x + -r2.z;
    r1.y = saturate(cb5[12].y * r1.y);
    r1.z = r2.x * r1.y;
    r3.xyz = -cb6[9].xyz + v6.xyz;
    r2.z = dot(r3.xyz, r3.xyz);
    r2.z = rsqrt(r2.z);
    r2.w = r3.y * r2.z;
    r3.x = cmp(r2.w < 0);
    r2.z = r3.y * r2.z + 1;
    r2.z = r2.z * r2.z;
    r3.yz = cb0[17].yz + -cb0[17].xy;
    r2.z = r2.z * r3.y + cb0[17].x;
    r2.w = r2.w * r3.z + cb0[17].y;
    r2.z = r3.x ? r2.z : r2.w;
    r3.xyz = cb0[7].xyz * r2.zzz;
    r3.xyz = r3.xyz * r0.www;
    r4.xyz = cb0[1].xyz * r0.www;
    r5.x = -r2.x * r1.y + 1;
    r6.x = r5.x * r2.y;
    r6.y = 1 + -r2.y;
    r6.z = r1.z * r2.y;
    r5.y = r6.y * r1.z;
    r5.z = r6.z;
    r1.yzw = r1.www ? r6.xyz : r5.xyz;
    r2.xyz = r3.xyz * r1.zzz;
    r2.xyz = r4.xyz * r1.yyy + r2.xyz;
    r0.xyz = r0.xyz * r1.www + r2.xyz;
    r1.x = 1;
    break;
    case 2 :    r1.y = cb5[13].y + cb5[12].z;
    r2.xyz = cb6[9].xyz + -v6.xyz;
    r1.z = dot(r2.xyz, r2.xyz);
    r1.z = sqrt(r1.z);
    r1.w = cmp(cb6[9].y < r1.y);
    if (r1.w != 0) {
      r1.w = -cb6[9].y + v6.y;
      r1.w = max(0, r1.w);
      r1.w = 9.99999975e-006 + r1.w;
      r2.x = -cb6[9].y + r1.y;
      r1.w = saturate(r2.x / r1.w);
      r2.x = r1.z * r1.w;
      r2.y = -r1.z * r1.w + r1.z;
      r2.z = cmp(0 < r2.y);
      if (r2.z != 0) {
        r1.w = 1 + -r1.w;
        r1.w = r1.z * r1.w;
        r2.z = v6.y + -r1.y;
        r2.w = 9.99999975e-006 + r2.y;
        r3.x = abs(r2.z) / r2.w;
        r3.x = cb5[10].x * r3.x;
        r3.y = cmp(r3.x == 0.000000);
        r3.z = -r3.x * r1.w;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = 1 + -r3.z;
        r3.x = r3.z / r3.x;
        r3.x = r3.y ? r1.w : r3.x;
        r3.y = min(v6.y, r1.y);
        r3.y = -cb5[10].x * r3.y;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = -cb5[10].y * r3.y;
        r3.x = r3.y * r3.x;
        r3.x = 1.44269502 * r3.x;
        r3.x = exp2(r3.x);
        r3.x = min(1, r3.x);
        r2.z = r2.z / r2.w;
        r2.z = cb0[14].z * r2.z;
        r2.w = cmp(r2.z == 0.000000);
        r3.y = -r2.z * r1.w;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = 1 + -r3.y;
        r2.z = r3.y / r2.z;
        r1.w = r2.w ? r1.w : r2.z;
        r2.z = -cb0[14].x + r1.y;
        r2.z = -cb0[14].z * r2.z;
        r2.z = 1.44269502 * r2.z;
        r2.z = exp2(r2.z);
        r2.z = -cb0[14].y * r2.z;
        r1.w = r2.z * r1.w;
        r1.w = 1.44269502 * r1.w;
        r1.w = exp2(r1.w);
        r1.w = min(1, r1.w);
        r3.x = r3.x * r1.w;
      } else {
        r3.x = 1;
      }
      r1.w = -cb5[12].w * r2.x;
      r1.w = 1.44269502 * r1.w;
      r1.w = exp2(r1.w);
      r3.y = min(1, r1.w);
    } else {
      r1.w = cb6[9].y + -v6.y;
      r1.w = max(0, r1.w);
      r1.w = 9.99999975e-006 + r1.w;
      r2.x = cb6[9].y + -r1.y;
      r1.w = saturate(r2.x / r1.w);
      r2.y = r1.z * r1.w;
      r2.x = -r1.z * r1.w + r1.z;
      r1.y = max(v6.y, r1.y);
      r2.z = -cb6[9].y + r1.y;
      r1.z = r1.z * r1.w + 9.99999975e-006;
      r1.w = abs(r2.z) / r1.z;
      r1.w = cb5[10].x * r1.w;
      r2.w = cmp(r1.w == 0.000000);
      r3.z = -r1.w * r2.y;
      r3.z = 1.44269502 * r3.z;
      r3.z = exp2(r3.z);
      r3.z = 1 + -r3.z;
      r1.w = r3.z / r1.w;
      r1.w = r2.w ? r2.y : r1.w;
      r1.y = min(cb6[9].y, r1.y);
      r1.y = -cb5[10].x * r1.y;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.y = -cb5[10].y * r1.y;
      r1.y = r1.y * r1.w;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.z = r2.z / r1.z;
      r1.z = cb0[14].z * r1.z;
      r1.w = cmp(r1.z == 0.000000);
      r2.z = -r1.z * r2.y;
      r2.z = 1.44269502 * r2.z;
      r2.z = exp2(r2.z);
      r2.z = 1 + -r2.z;
      r1.z = r2.z / r1.z;
      r1.z = r1.w ? r2.y : r1.z;
      r1.w = cb6[9].y + -cb0[14].x;
      r1.w = -cb0[14].z * r1.w;
      r1.w = 1.44269502 * r1.w;
      r1.w = exp2(r1.w);
      r1.w = -cb0[14].y * r1.w;
      r1.z = r1.w * r1.z;
      r1.z = 1.44269502 * r1.z;
      r1.z = exp2(r1.z);
      r1.yz = min(float2(1,1), r1.yz);
      r3.x = r1.y * r1.z;
      r1.y = -cb5[12].w * r2.x;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r3.y = min(1, r1.y);
    }
    r1.y = cb5[12].x + -r2.y;
    r1.y = saturate(cb5[12].y * r1.y);
    r1.y = r3.x * r1.y;
    r1.x = r1.y * r3.y;
    break;
    default :
    r1.x = 1;
    break;
  }
  o0.xyzw = r1.xxxx * r0.xyzw;
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.2.67 on Fri Dec 01 18:49:06 2017
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xy  
// TEXCOORD                 6   xyzw        1     NONE   float   xyzw
// TEXCOORD                 7   xyzw        2     NONE   float      w
// TEXCOORD                 4   xyzw        3     NONE   float   xyz 
// TEXCOORD                 5   xyzw        4     NONE   float       
// COLOR                    0   xyzw        5     NONE   float   xyz 
// COLOR                    1   xyzw        6     NONE   float   xyzw
// TEXCOORD                10   xyz         7     NONE   float   xyz 
// TEXCOORD                11      w        7     NONE   float      w
// TEXCOORD                 0   xyzw        8     NONE   float   xyzw
// TEXCOORD                 1   xyzw        9     NONE   float   xy  
// TEXCOORD                 2   xyzw       10     NONE   float       
// TEXCOORD                 3   xyzw       11     NONE   float   xyz 
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_Target                0   xyzw        0   TARGET   float   xyzw
//
ps_5_0
dcl_globalFlags refactoringAllowed
dcl_immediateConstantBuffer { { 0.0153846154, 0, 0, 0},
                              { 0.753846169, 0, 0, 0},
                              { 0.200000, 0, 0, 0},
                              { 0.938461542, 0, 0, 0},
                              { 0.0615384616, 0, 0, 0},
                              { 0.800000, 0, 0, 0},
                              { 0.246153846, 0, 0, 0},
                              { 0.984615386, 0, 0, 0},
                              { 0.507692337, 0, 0, 0},
                              { 0.261538476, 0, 0, 0},
                              { 0.692307711, 0, 0, 0},
                              { 0.446153849, 0, 0, 0},
                              { 0.553846180, 0, 0, 0},
                              { 0.307692319, 0, 0, 0},
                              { 0.738461554, 0, 0, 0},
                              { 0.492307693, 0, 0, 0},
                              { 0.138461545, 0, 0, 0},
                              { 0.876923084, 0, 0, 0},
                              { 0.0769230798, 0, 0, 0},
                              { 0.815384626, 0, 0, 0},
                              { 0.184615389, 0, 0, 0},
                              { 0.923076928, 0, 0, 0},
                              { 0.123076923, 0, 0, 0},
                              { 0.861538470, 0, 0, 0},
                              { 0.630769253, 0, 0, 0},
                              { 0.384615391, 0, 0, 0},
                              { 0.569230795, 0, 0, 0},
                              { 0.323076934, 0, 0, 0},
                              { 0.676923096, 0, 0, 0},
                              { 0.430769235, 0, 0, 0},
                              { 0.615384638, 0, 0, 0},
                              { 0.369230777, 0, 0, 0},
                              { 0.0461538471, 0, 0, 0},
                              { 0.784615397, 0, 0, 0},
                              { 0.230769232, 0, 0, 0},
                              { 0.969230771, 0, 0, 0},
                              { 0.0307692308, 0, 0, 0},
                              { 0.769230783, 0, 0, 0},
                              { 0.215384617, 0, 0, 0},
                              { 0.953846157, 0, 0, 0},
                              { 0.538461566, 0, 0, 0},
                              { 0.292307705, 0, 0, 0},
                              { 0.723076940, 0, 0, 0},
                              { 0.476923078, 0, 0, 0},
                              { 0.523076952, 0, 0, 0},
                              { 0.276923090, 0, 0, 0},
                              { 0.707692325, 0, 0, 0},
                              { 0.461538464, 0, 0, 0},
                              { 0.169230774, 0, 0, 0},
                              { 0.907692313, 0, 0, 0},
                              { 0.107692309, 0, 0, 0},
                              { 0.846153855, 0, 0, 0},
                              { 0.153846160, 0, 0, 0},
                              { 0.892307699, 0, 0, 0},
                              { 0.0923076943, 0, 0, 0},
                              { 0.830769241, 0, 0, 0},
                              { 0.661538482, 0, 0, 0},
                              { 0.415384620, 0, 0, 0},
                              { 0.600000, 0, 0, 0},
                              { 0.353846163, 0, 0, 0},
                              { 0.646153867, 0, 0, 0},
                              { 0.400000, 0, 0, 0},
                              { 0.584615409, 0, 0, 0},
                              { 0.338461548, 0, 0, 0} }
dcl_constantbuffer cb0[18], immediateIndexed
dcl_constantbuffer cb5[14], immediateIndexed
dcl_constantbuffer cb6[10], immediateIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_sampler s2, mode_default
dcl_resource_texture2d (float,float,float,float) t0
dcl_resource_texture2d (float,float,float,float) t1
dcl_resource_texture2d (float,float,float,float) t2
dcl_resource_texture2d (float,float,float,float) t16
dcl_input_ps_siv linear noperspective v0.xy, position
dcl_input_ps linear centroid v1.xyzw
dcl_input_ps linear centroid v2.w
dcl_input_ps linear centroid v3.xyz
dcl_input_ps linear centroid v5.xyz
dcl_input_ps linear centroid v6.xyzw
dcl_input_ps linear centroid v7.xyz
dcl_input_ps linear centroid v7.w
dcl_input_ps linear centroid v8.xyzw
dcl_input_ps linear centroid v9.xy
dcl_input_ps linear centroid v11.xyz
dcl_output o0.xyzw
dcl_temps 7
sample_indexable(texture2d)(float,float,float,float) r0.xyzw, v8.wzww, t1.xyzw, s1
sample_indexable(texture2d)(float,float,float,float) r1.xy, v9.xyxx, t2.yzxw, s2
add r0.x, -r0.w, r0.x
add r0.xyz, r0.xyzx, l(1.000000, 0.000000, 0.000000, 0.000000)
mad r0.xyz, r0.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.000000, -1.000000, -1.000000, 0.000000)
dp3 r0.w, r0.xyzx, r0.xyzx
rsq r0.w, r0.w
mul r0.xyz, r0.wwww, r0.xyzx
dp3 r0.w, r0.xyzx, v5.xyzx
dp3 r1.z, r0.xyzx, v11.xyzx
mul r1.y, r1.y, cb5[6].w
ge r1.w, r0.w, l(0.000000)
max r2.x, r0.w, l(0.000000)
ge r2.y, r1.z, l(0.000000)
and r1.w, r1.w, r2.y
log r1.z, r1.z
mul r1.y, r1.z, r1.y
exp r1.y, r1.y
and r1.y, r1.y, r1.w
min r1.y, r1.y, l(1.000000)
max r0.w, -r0.w, l(0.000000)
dp3 r0.x, r0.xyzx, v3.xyzx
add_sat r0.y, r0.x, l(1.000000)
mov_sat r0.z, r0.x
add r2.yzw, cb5[1].xxyz, -cb5[9].xxyz
mad r2.yzw, r0.zzzz, r2.yyzw, cb5[9].xxyz
add r3.xyz, -cb5[2].xyzx, cb5[9].xyzx
mad r3.xyz, r0.yyyy, r3.xyzx, cb5[2].xyzx
lt r0.y, l(0.000000), r0.x
lt r0.x, r0.x, l(0.000000)
iadd r0.x, r0.x, -r0.y
itof r0.x, r0.x
mov_sat r0.x, r0.x
add r2.yzw, r2.yyzw, -r3.xxyz
mad r0.xyz, r0.xxxx, r2.yzwy, r3.xyzx
add r0.xyz, r0.xyzx, cb5[8].xyzx
add r0.xyz, r0.xyzx, v1.xyzx
mad r0.xyz, cb5[5].xyzx, r0.wwww, r0.xyzx
mul r2.xyz, r2.xxxx, cb5[4].xyzx
add r0.w, -r1.x, l(1.000000)
mad r2.xyz, r2.xyzx, r0.wwww, cb5[3].xyzx
mul r1.yzw, r1.yyyy, cb5[6].xxyz
mul r1.xyz, r1.xxxx, r1.yzwy
sample_indexable(texture2d)(float,float,float,float) r3.xyzw, v8.xyxx, t0.xyzw, s0
mul r3.xyzw, r3.xyzw, cb6[1].xyzw
mul_sat r0.w, r3.w, v1.w
lt r4.xy, l(0.000000, 0.000000, 0.000000, 0.000000), cb6[4].xzxx
add r1.w, r0.w, -cb6[4].y
lt r1.w, r1.w, l(0.000000)
and r1.w, r4.x, r1.w
discard_nz r1.w
max r0.w, r0.w, cb5[0].w
if_nz r4.y
  ftoi r4.xy, v0.yxyy
  and r4.zw, r4.xxxy, l(0, 0, 0x80000000, 0x80000000)
  imax r4.xy, r4.xyxx, -r4.xyxx
  and r4.xy, r4.xyxx, l(7, 7, 0, 0)
  ineg r5.xy, r4.xyxx
  movc r4.xy, r4.zwzz, r5.xyxx, r4.xyxx
  ishl r1.w, r4.y, l(3)
  iadd r1.w, r1.w, r4.x
  lt r2.w, l(0.000000), v7.w
  lt r3.w, v7.w, l(0.000000)
  iadd r2.w, r3.w, -r2.w
  itof r2.w, r2.w
  add r1.w, v7.w, -icb[r1.w + 0].x
  add r3.w, r2.w, l(-1.000000)
  mul r3.w, r3.w, l(0.500000)
  mad r1.w, r2.w, r1.w, r3.w
  lt r1.w, r1.w, l(0.000000)
  discard_nz r1.w
endif 
add r1.w, -v6.w, cb5[12].z
max r1.w, r1.w, l(0.000000)
mul r4.xyz, -r1.wwww, cb0[15].xyzx
mul r4.xyz, r4.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r4.xyz, r4.xyzx
mul r5.xyz, -r1.wwww, cb0[16].xyzx
mul r5.xyz, r5.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r5.xyz, r5.xyzx
mul r2.xyz, r2.xyzx, r5.xyzx
mul r0.xyz, r0.xyzx, r4.xyzx
mul r1.xyz, r1.xyzx, r5.xyzx
mul r4.xy, v0.xyxx, cb0[12].xyxx
ftoi r4.xy, r4.xyxx
mov r4.zw, l(0,0,0,0)
ld_indexable(texture2d)(float,float,float,float) r4.xyzw, r4.xyzw, t16.xyzw
mul r5.xyz, r2.xyzx, cb0[10].wwww
mul r4.yzw, r4.yyzw, r5.xxyz
add r1.w, r4.x, l(-1.000000)
mad r1.w, r0.w, r1.w, l(1.000000)
mad r2.xyz, r4.yzwy, r0.wwww, r2.xyzx
mad r0.xyz, r0.xyzx, r1.wwww, v7.xyzx
add r1.w, -v2.w, l(1.000000)
add_sat r1.w, -r1.w, l(1.000000)
mad r0.xyz, r2.xyzx, r1.wwww, r0.xyzx
mul r0.xyz, r3.xyzx, r0.xyzx
mul r1.xyz, r1.wwww, r1.xyzx
mad r0.xyz, r0.xyzx, r0.wwww, r1.xyzx
switch cb5[11].x
  case l(1)
  case l(3)
  add r1.y, cb5[12].z, cb5[13].y
  add r2.xyz, -v6.xyzx, cb6[9].xyzx
  dp3 r1.z, r2.xyzx, r2.xyzx
  sqrt r1.z, r1.z
  lt r1.w, cb6[9].y, r1.y
  if_nz r1.w
    add r2.x, v6.y, -cb6[9].y
    max r2.x, r2.x, l(0.000000)
    add r2.x, r2.x, l(0.000010)
    add r2.y, r1.y, -cb6[9].y
    div_sat r2.x, r2.y, r2.x
    mul r2.y, r1.z, r2.x
    mad r2.z, -r1.z, r2.x, r1.z
    lt r2.w, l(0.000000), r2.z
    if_nz r2.w
      add r2.x, -r2.x, l(1.000000)
      mul r2.x, r1.z, r2.x
      add r2.w, -r1.y, v6.y
      add r3.x, r2.z, l(0.000010)
      div r3.y, |r2.w|, r3.x
      mul r3.y, r3.y, cb5[10].x
      eq r3.z, r3.y, l(0.000000)
      mul r3.w, r2.x, -r3.y
      mul r3.w, r3.w, l(1.442695)
      exp r3.w, r3.w
      add r3.w, -r3.w, l(1.000000)
      div r3.y, r3.w, r3.y
      movc r3.y, r3.z, r2.x, r3.y
      min r3.z, r1.y, v6.y
      mul r3.z, r3.z, -cb5[10].x
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      mul r3.z, r3.z, -cb5[10].y
      mul r3.y, r3.y, r3.z
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      min r3.y, r3.y, l(1.000000)
      div r2.w, r2.w, r3.x
      mul r2.w, r2.w, cb0[14].z
      eq r3.x, r2.w, l(0.000000)
      mul r3.z, r2.x, -r2.w
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      add r3.z, -r3.z, l(1.000000)
      div r2.w, r3.z, r2.w
      movc r2.x, r3.x, r2.x, r2.w
      add r2.w, r1.y, -cb0[14].x
      mul r2.w, r2.w, -cb0[14].z
      mul r2.w, r2.w, l(1.442695)
      exp r2.w, r2.w
      mul r2.w, r2.w, -cb0[14].y
      mul r2.x, r2.x, r2.w
      mul r2.x, r2.x, l(1.442695)
      exp r2.x, r2.x
      min r2.x, r2.x, l(1.000000)
      mul r2.x, r2.x, r3.y
    else 
      mov r2.x, l(1.000000)
    endif 
    mul r2.y, r2.y, -cb5[12].w
    mul r2.y, r2.y, l(1.442695)
    exp r2.y, r2.y
    min r2.y, r2.y, l(1.000000)
  else 
    add r2.w, -v6.y, cb6[9].y
    max r2.w, r2.w, l(0.000000)
    add r2.w, r2.w, l(0.000010)
    add r3.x, -r1.y, cb6[9].y
    div_sat r2.w, r3.x, r2.w
    mul r2.z, r1.z, r2.w
    mad r3.x, -r1.z, r2.w, r1.z
    max r1.y, r1.y, v6.y
    add r3.y, r1.y, -cb6[9].y
    mad r1.z, r1.z, r2.w, l(0.000010)
    div r2.w, |r3.y|, r1.z
    mul r2.w, r2.w, cb5[10].x
    eq r3.z, r2.w, l(0.000000)
    mul r3.w, r2.z, -r2.w
    mul r3.w, r3.w, l(1.442695)
    exp r3.w, r3.w
    add r3.w, -r3.w, l(1.000000)
    div r2.w, r3.w, r2.w
    movc r2.w, r3.z, r2.z, r2.w
    min r1.y, r1.y, cb6[9].y
    mul r1.y, r1.y, -cb5[10].x
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    mul r1.y, r1.y, -cb5[10].y
    mul r1.y, r2.w, r1.y
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    div r1.z, r3.y, r1.z
    mul r1.z, r1.z, cb0[14].z
    eq r2.w, r1.z, l(0.000000)
    mul r3.y, r2.z, -r1.z
    mul r3.y, r3.y, l(1.442695)
    exp r3.y, r3.y
    add r3.y, -r3.y, l(1.000000)
    div r1.z, r3.y, r1.z
    movc r1.z, r2.w, r2.z, r1.z
    add r2.w, -cb0[14].x, cb6[9].y
    mul r2.w, r2.w, -cb0[14].z
    mul r2.w, r2.w, l(1.442695)
    exp r2.w, r2.w
    mul r2.w, r2.w, -cb0[14].y
    mul r1.z, r1.z, r2.w
    mul r1.z, r1.z, l(1.442695)
    exp r1.z, r1.z
    min r1.yz, r1.yyzy, l(0.000000, 1.000000, 1.000000, 0.000000)
    mul r2.x, r1.z, r1.y
    mul r1.y, r3.x, -cb5[12].w
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    min r2.y, r1.y, l(1.000000)
  endif 
  add r1.y, -r2.z, cb5[12].x
  mul_sat r1.y, r1.y, cb5[12].y
  mul r1.z, r1.y, r2.x
  add r3.xyz, v6.xyzx, -cb6[9].xyzx
  dp3 r2.z, r3.xyzx, r3.xyzx
  rsq r2.z, r2.z
  mul r2.w, r2.z, r3.y
  lt r3.x, r2.w, l(0.000000)
  mad r2.z, r3.y, r2.z, l(1.000000)
  mul r2.z, r2.z, r2.z
  add r3.yz, -cb0[17].xxyx, cb0[17].yyzy
  mad r2.z, r2.z, r3.y, cb0[17].x
  mad r2.w, r2.w, r3.z, cb0[17].y
  movc r2.z, r3.x, r2.z, r2.w
  mul r3.xyz, r2.zzzz, cb0[7].xyzx
  mul r3.xyz, r0.wwww, r3.xyzx
  mul r4.xyz, r0.wwww, cb0[1].xyzx
  mad r5.x, -r2.x, r1.y, l(1.000000)
  mul r6.x, r2.y, r5.x
  add r6.y, -r2.y, l(1.000000)
  mul r6.z, r2.y, r1.z
  mul r5.y, r1.z, r6.y
  mov r5.z, r6.z
  movc r1.yzw, r1.wwww, r6.xxyz, r5.xxyz
  mul r2.xyz, r1.zzzz, r3.xyzx
  mad r2.xyz, r4.xyzx, r1.yyyy, r2.xyzx
  mad r0.xyz, r0.xyzx, r1.wwww, r2.xyzx
  mov r1.x, l(1.000000)
  break 
  case l(2)
  add r1.y, cb5[12].z, cb5[13].y
  add r2.xyz, -v6.xyzx, cb6[9].xyzx
  dp3 r1.z, r2.xyzx, r2.xyzx
  sqrt r1.z, r1.z
  lt r1.w, cb6[9].y, r1.y
  if_nz r1.w
    add r1.w, v6.y, -cb6[9].y
    max r1.w, r1.w, l(0.000000)
    add r1.w, r1.w, l(0.000010)
    add r2.x, r1.y, -cb6[9].y
    div_sat r1.w, r2.x, r1.w
    mul r2.x, r1.w, r1.z
    mad r2.y, -r1.z, r1.w, r1.z
    lt r2.z, l(0.000000), r2.y
    if_nz r2.z
      add r1.w, -r1.w, l(1.000000)
      mul r1.w, r1.w, r1.z
      add r2.z, -r1.y, v6.y
      add r2.w, r2.y, l(0.000010)
      div r3.x, |r2.z|, r2.w
      mul r3.x, r3.x, cb5[10].x
      eq r3.y, r3.x, l(0.000000)
      mul r3.z, r1.w, -r3.x
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      add r3.z, -r3.z, l(1.000000)
      div r3.x, r3.z, r3.x
      movc r3.x, r3.y, r1.w, r3.x
      min r3.y, r1.y, v6.y
      mul r3.y, r3.y, -cb5[10].x
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      mul r3.y, r3.y, -cb5[10].y
      mul r3.x, r3.x, r3.y
      mul r3.x, r3.x, l(1.442695)
      exp r3.x, r3.x
      min r3.x, r3.x, l(1.000000)
      div r2.z, r2.z, r2.w
      mul r2.z, r2.z, cb0[14].z
      eq r2.w, r2.z, l(0.000000)
      mul r3.y, r1.w, -r2.z
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      add r3.y, -r3.y, l(1.000000)
      div r2.z, r3.y, r2.z
      movc r1.w, r2.w, r1.w, r2.z
      add r2.z, r1.y, -cb0[14].x
      mul r2.z, r2.z, -cb0[14].z
      mul r2.z, r2.z, l(1.442695)
      exp r2.z, r2.z
      mul r2.z, r2.z, -cb0[14].y
      mul r1.w, r1.w, r2.z
      mul r1.w, r1.w, l(1.442695)
      exp r1.w, r1.w
      min r1.w, r1.w, l(1.000000)
      mul r3.x, r1.w, r3.x
    else 
      mov r3.x, l(1.000000)
    endif 
    mul r1.w, r2.x, -cb5[12].w
    mul r1.w, r1.w, l(1.442695)
    exp r1.w, r1.w
    min r3.y, r1.w, l(1.000000)
  else 
    add r1.w, -v6.y, cb6[9].y
    max r1.w, r1.w, l(0.000000)
    add r1.w, r1.w, l(0.000010)
    add r2.x, -r1.y, cb6[9].y
    div_sat r1.w, r2.x, r1.w
    mul r2.y, r1.w, r1.z
    mad r2.x, -r1.z, r1.w, r1.z
    max r1.y, r1.y, v6.y
    add r2.z, r1.y, -cb6[9].y
    mad r1.z, r1.z, r1.w, l(0.000010)
    div r1.w, |r2.z|, r1.z
    mul r1.w, r1.w, cb5[10].x
    eq r2.w, r1.w, l(0.000000)
    mul r3.z, r2.y, -r1.w
    mul r3.z, r3.z, l(1.442695)
    exp r3.z, r3.z
    add r3.z, -r3.z, l(1.000000)
    div r1.w, r3.z, r1.w
    movc r1.w, r2.w, r2.y, r1.w
    min r1.y, r1.y, cb6[9].y
    mul r1.y, r1.y, -cb5[10].x
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    mul r1.y, r1.y, -cb5[10].y
    mul r1.y, r1.w, r1.y
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    div r1.z, r2.z, r1.z
    mul r1.z, r1.z, cb0[14].z
    eq r1.w, r1.z, l(0.000000)
    mul r2.z, r2.y, -r1.z
    mul r2.z, r2.z, l(1.442695)
    exp r2.z, r2.z
    add r2.z, -r2.z, l(1.000000)
    div r1.z, r2.z, r1.z
    movc r1.z, r1.w, r2.y, r1.z
    add r1.w, -cb0[14].x, cb6[9].y
    mul r1.w, r1.w, -cb0[14].z
    mul r1.w, r1.w, l(1.442695)
    exp r1.w, r1.w
    mul r1.w, r1.w, -cb0[14].y
    mul r1.z, r1.z, r1.w
    mul r1.z, r1.z, l(1.442695)
    exp r1.z, r1.z
    min r1.yz, r1.yyzy, l(0.000000, 1.000000, 1.000000, 0.000000)
    mul r3.x, r1.z, r1.y
    mul r1.y, r2.x, -cb5[12].w
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    min r3.y, r1.y, l(1.000000)
  endif 
  add r1.y, -r2.y, cb5[12].x
  mul_sat r1.y, r1.y, cb5[12].y
  mul r1.y, r1.y, r3.x
  mul r1.x, r3.y, r1.y
  break 
  default 
  mov r1.x, l(1.000000)
  break 
endswitch 
mul o0.xyzw, r0.xyzw, r1.xxxx
ret 
// Approximately 0 instruction slots used

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
